From: Mukesh Rathor Date: Wed, 13 Nov 2013 08:35:58 +0000 (+0100) Subject: pvh: do not allow PVH guests to change paging modes X-Git-Tag: archive/raspbian/4.8.0-1+rpi1~1^2~5968 X-Git-Url: https://dgit.raspbian.org/%22http:/www.example.com/cgi/%22https://%22%22/%22http:/www.example.com/cgi/%22https:/%22%22?a=commitdiff_plain;h=9001eb540b815110302505cfd799f1356f40e47f;p=xen.git pvh: do not allow PVH guests to change paging modes Signed-off-by: Mukesh Rathor Signed-off-by: George Dunlap Reviewed-by: Jan Beulich Acked-by: Tim Deegan Acked-by: Keir Fraser Acked-by: Eddie Dong --- diff --git a/xen/arch/x86/hvm/hvm.c b/xen/arch/x86/hvm/hvm.c index 484319f8eb..4df46bee09 100644 --- a/xen/arch/x86/hvm/hvm.c +++ b/xen/arch/x86/hvm/hvm.c @@ -1818,6 +1818,15 @@ int hvm_set_cr0(unsigned long value) (value & (X86_CR0_PE | X86_CR0_PG)) == X86_CR0_PG ) goto gpf; + /* A pvh is not expected to change to real mode. */ + if ( is_pvh_vcpu(v) + && (value & (X86_CR0_PE | X86_CR0_PG)) != (X86_CR0_PG | X86_CR0_PE) ) + { + printk(XENLOG_G_WARNING + "PVH attempting to turn off PE/PG. CR0:%lx\n", value); + goto gpf; + } + if ( (value & X86_CR0_PG) && !(old_value & X86_CR0_PG) ) { if ( v->arch.hvm_vcpu.guest_efer & EFER_LME )